Coverage Report

Created: 2024-12-26 12:25

next uncovered line (L), next uncovered region (R), next uncovered branch (B)
D:\a\tools.proto\tools.proto\compiler\src\gen\base\message_write.rs
Line
Count
Source
1
// Copyright (c) 2024, BlockProject 3D
2
//
3
// All rights reserved.
4
//
5
// Redistribution and use in source and binary forms, with or without modification,
6
// are permitted provided that the following conditions are met:
7
//
8
//     * Redistributions of source code must retain the above copyright notice,
9
//       this list of conditions and the following disclaimer.
10
//     * Redistributions in binary form must reproduce the above copyright notice,
11
//       this list of conditions and the following disclaimer in the documentation
12
//       and/or other materials provided with the distribution.
13
//     * Neither the name of BlockProject 3D nor the names of its contributors
14
//       may be used to endorse or promote products derived from this software
15
//       without specific prior written permission.
16
//
17
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
18
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
19
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
20
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
21
// CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
22
// EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
23
// PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
24
// PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF
25
// LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
26
// NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
27
// SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28
29
use crate::compiler::message::{Field, Message};
30
use crate::compiler::util::types::TypeMapper;
31
use crate::gen::base::map::TypePathMapper;
32
use crate::gen::base::message::{Templates, Utilities};
33
use crate::gen::base::message_common::generate_field_type_inline;
34
use crate::gen::base::Error;
35
36
91
fn gen_field_write_impl<U: Utilities, T: TypeMapper>(
37
91
    field: &Field,
38
91
    templates: &Templates,
39
91
    type_path_map: &TypePathMapper<T>,
40
91
    function: &str,
41
91
) -> Result<String, Error> {
42
91
    let mut scope = templates.template.scope();
43
91
    scope.var("name", &field.name);
44
91
    let codec_template = templates.get(field.codec())
?0
;
45
91
    let msg_type = generate_field_type_inline::<U, T>(field, codec_template, type_path_map, "write")
?0
;
46
91
    if let Some(
header22
) = &field.header {
  Branch (46:12): [True: 22, False: 69]
  Branch (46:12): [True: 0, False: 0]
  Branch (46:12): [Folded - Ignored]
47
22
        scope.var("header_name", &header.name);
48
69
    }
49
91
    scope.var("type", msg_type);
50
91
    if field.header.is_some() && 
field.ty.is_union()22
{
  Branch (50:8): [True: 22, False: 69]
  Branch (50:34): [True: 10, False: 12]
  Branch (50:8): [True: 0, False: 0]
  Branch (50:34): [True: 0, False: 0]
  Branch (50:8): [Folded - Ignored]
  Branch (50:34): [Folded - Ignored]
51
10
        Ok(scope.render(function, &["field_union"]).unwrap())
52
81
    } else if field.header.is_some() {
  Branch (52:15): [True: 12, False: 69]
  Branch (52:15): [True: 0, False: 0]
  Branch (52:15): [Folded - Ignored]
53
12
        Ok(scope.render(function, &["field_header"]).unwrap())
54
69
    } else if field.ty.is_string() {
  Branch (54:15): [True: 25, False: 44]
  Branch (54:15): [True: 0, False: 0]
  Branch (54:15): [Folded - Ignored]
55
25
        Ok(scope.render(function, &["field_string"]).unwrap())
56
    } else {
57
44
        Ok(scope.render(function, &["field"]).unwrap())
58
    }
59
91
}
60
61
45
pub fn generate<'variable, U: Utilities, T: TypeMapper>(
62
45
    mut templates: Templates<'_, 'variable>,
63
45
    msg: &'variable Message,
64
45
    type_path_map: &TypePathMapper<T>,
65
45
    function: &str,
66
45
) -> Result<String, Error> {
67
45
    templates.template.var("msg_name", &msg.name);
68
45
    let fields = msg
69
45
        .fields
70
45
        .iter()
71
91
        .map(|field| gen_field_write_impl::<U, T>(field, &templates, type_path_map, function))
72
45
        .collect::<Result<Vec<String>, Error>>()
?0
73
45
        .join("");
74
45
    Ok(templates.template.var("fields", fields).render("", &[function]).unwrap())
75
45
}